package com.leetcode.sorts.string;

/**
 * @Author: WuPeng
 * @Date: 2021/5/31 4:12 下午
 *
 * 剑指 Offer 58-2.左旋转字符串
 * 字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。
 * 比如，输入字符串"abcdefg"和数字2，该函数将返回左旋转两位得到的结果"cdefgab"。
 *
 * 示例 1：
 *      输入: s = "abcdefg", k = 2
 *      输出:"cdefgab"
 * 示例 2：
 *      输入: s = "lrloseumgh", k = 6
 *      输出:"umghlrlose"
 *
 */
public class LeftReverseString {
    public static String reverseLeftWords(String s, int n) {
        int len = s.length();
        int slow = 0, fast = n;
        StringBuilder sb = new StringBuilder();
        while(fast < len){
            sb.append(s.charAt(fast++));
        }
        while(slow < n){
            sb.append(s.charAt(slow++));
        }
        return sb.toString();
    }

    public static void main(String[] args) {
        String str = "abcdefg";
        System.out.println(reverseLeftWords(str,3));
    }

}
